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A system for synthesizing field programmable gate array implementations from high level circuit 
description. 



@ A system is disclosed for synthesizing field, 
programmable gate array (FPGA) implemen- 
tations from high level circuit descriptions. A 
designer may describe circuits using a textual 
language or a graphics tool. The system will 
compile such circuit descriptions Into technol- 
ogy mapped descriptions for use with FPGA's. 

The system will support both random logic 
circuits and data path circuits. The system uses 
advanced optimization techniques to produce 
efficient FPGA implementations. Thus, the sys- 
. tern pnDduces high quality results while provid- 
ing users with a high level of abstraction in 
design, and thus frees the user from archi- 
tectural details of the target FPGA. 
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Field of the Invention ^ 

J 

This invention relates generally to computer aided design (CAD) of electronic circuits. More particularly, 
the present invention relates to a synthesis system for developing field programmable gate array (FPGA) inv 
5 plementations from high ievel descriptions of electronic circuits. The system pnDduces high quality results while 
providing users with a high level of abstraction in design, and thus frees users from the architectural details 
of the FPGA. 

Background of the Invention 

10 

A field programmable gate array (FPGA) consists of a matrix of programmable logic cells and progranrv 
mable routing between the programmable logic cells. Each logic cell typically contains various electronic conrv 
ponents such as static RAM ceils, multiplexers and flip-flops. The functionality of each logic cell may be pro- 
grammed by writing to the static ram cells and changing the internal configuration of the logic cell. 

15 Similarly, the logic cells within the FPGA are also connected to each other by programmable connection 

points (e.g. static RAM cells or antifuse points) to allow programmable routing. By writing to these static ram 
cells, the routing between logic cells may be programmed, and the configuration of the FPGA determined. 

Initially, first generation FPGA's were well-suited to implement random logic circuits. Arandom logic circuit 
is a collection of electronic components, such as logic gates, to implement control functions. The then existing 

20 CAD design tools were suitable for these first generation FPGA's. 

Next generation FPGA's were subsequently developed which supported data path circuits. Data path cir- 
cuits are circuits which manipulate data in groups. For example, some of the basic elements of data path cir- 
cuits are accumulators, registers, memory, etc. For example, the Optimized Reconf igurable Cell Array (ORCA) 
FPGA, developed by AT&T, supports data path circuits in many ways. Each logic cell, called a Programmable 

25 Logic Cluster (PLC), can perform data manipulation operations on 4-bit data or a pair of 4-bit data. Each PLC 
contains fast carry logic for addition and subtraction operations. This carry logic is also used when a PLC is 
used as a (4-bit) counter. Each PLC can be used as a 16 x 4 RAM. The routing structure supports 4-bit wide 
routing. 

The existing CAD systems could not exploit the data path capabilities of the second generation FPGA's 
30 because these CAD systems were geared toward random logic circuits and could not handle data path circuits 
well. 

Summary of the Invention 

35 The present invention is an FPGA synthesis system which supports both data path circuits and random 

logic circuits. It provides users with a set of parameterizable modules so that they can describe a circuit as a 
collection of those modules. Using the circuit descriptions, the invention will generate technology mapped de- 
scriptions for implementation on a particular FPGA using advanced optimization techniques. The mapped cir- 
cuits can then be placed and routed by existing CAD tools. In describing circuits, users may use either a textual 

40 language or a graphics tool. The graphics tool will automatically produce the textual language description of 

' the circuit. 

In particular, the present invention will determine how many of the FPGA's logic cells will be used, the func- 
tion and configuration of each logic cell, and how the individual logic cells are to be connected. The output 
from the present invention can then be used by other lower level CAD tools for the placement (i.e. where to 
45 place each logic cell within the FPGA chip) and routing (i.e. the connections between the individual logic cells). 

The present invention has many merits. By way of example, it exploits data path circuits of cunrent FPGA's. 
It provides users with a higher level of abstraction (than gates and flip-flops) for circuit design. It frees users 
from architectural details of a particular FPGA and. as a result, it increases productivity of circuit design for 
the FPGA. Also, it produces high quality results. Other advantages of the present invention will be readily ap- 
50 parent from the detailed description which follows. 

Description of the Drawings 

Fig. 1 shows a high level design flow using the present invention. 
55 Fig. 2 shows a schematic of the components of the system of the present invention. 

Fig. 3 shows a 4-to-1 multiplexer. 

Fig. 4 shows a multiplexer group consisting of four 2-to-1 multiplexers. 
Fig. 5 shows a finite state machine state graph. 
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(57) A system is disclosed for synthesizing field pro- 
grammable gate array (FPGA) implementations from 
high level circuit descriptions. A designer may describe 
circuits using a textual language or a graphics tool. The 
system will compile such circuit descriptions into tech- 
nology mapped descriptions for use with FPGA's. 

The system will support both random logic circuits 
and data path circuits. The system uses advanced op- 
timization techniques to produce efficient FPGA imple- 
mentations. Thus, the system produces high quality re- 
sults while providing users with a high level of abstrac- 
^Jion in design, and thus frees the user from architectural 
details of the target FPGA. 
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Fig. 6 shows a screen display of the graphics tool. 
Fig. 7 shows an alternative screen display of the graphics tool. 
Fig. 8 shows an end user flow diagram for the graphics tool. 
Fig. 9 shows a block diagram of the ORCA FPGA programmable logic cluster. 
5 Fig. 10 shows a flow diagram of the compiler/optimizer. 

Fig. 11 shows a flow diagram of phase 1 optimization. 
Fig. 12 illustrates the benefits of optimization by changing signal polarities. 
Fig. 13A shows a user defined 32X4 memory. 

Fig. 13B shows a compiled circuit of the user defined 32x4 memory of Fig. 13A. 
10 Fig. 14A shows a user defined 10-bit adder. 

Fig. 14B shows a compiled circuit of the user defined 10-bit adder of Fig. 14A. 
Fig. 15A shows an 11 -bit counter. 

Fig. 15B shows an implementation of the 11-bit counter shown in Fig. 15A. 

Fig. 16A shows the implementation of a 4-to-1 multiplexer in one logic cell with 4 16-bit lookup tables. 
15 Fig. 16B shows the implementation of a 4-to-1 multiplexer in three logic cells using three 16-bit lookup 

tables. 

Fig. 17 shows a user defined 8-to-1 multiplexer. 

Fig. 18 shows an implementation of the user defined 8-to-1 multiplexer of Fig. 17. 
Fig. 19 shows an implementation of the user defined 8-to-1 multiplexer of Fig. 17. 
20 Fig. 20 shows an implementation of the user defined 8-to-1 multiplexer of Fig. 17. 

Fig. 21 shows a flow diagram of phase 2 optimization. 
Fig. 22 shows an example of merging two logic cells together. 
Fig. 23 shows a block diagram of a user defined circuit. 

Fig. 24 shows a block diagram of an FPGA implementation of the circuit in Fig. 23. 
25 Fig. 25 shows a block diagram of an optimized FPGA implementation of the circuit in Fig. 23. 

Detailed Description 

An overview of a system 114 according to the present invention is shown in Fig. 1. A user 102 interacts 

30 with the system by a graphics tool 104 or by entering a high level application netlist (HAN) 106 language de- 
scription of the circuit directly. A compiler/optimizer 108 generates an FPGA application netlist (FAN) file 110, 
which is mapped to the specific FPGA technology being used. This FAN file describes the FPGA implemen- 
tation which was synthesized by the system in a language which is appropriate for the specific CAD system 
on which the invention is being implemented. The file 110 contains information specifying the number of logic 

35 cells being used, the functionality (or configuration) of each logic cell and connection requirement between 
logic cells. This FAN file 110 is then used as the input to the lower level CAD tools for placement and routing 
1 1 2. The placement tool determines the location of eachlogic cell specified in file 1 1 0. The routing tool allocates 
hardware resources in the FPGA chip to satisfy the connection requirement in file 110. These lower level CAD 
tools will result in the FPGA implementation 116. 

40 One embodiment of the present invention may be implemented using a general purpose computer system 

such as the one illustrated in Fig. 2. Fig. 2 shows a general purpose computer system 200 comprising a graph- 
^"^ — ' ical display monitor 202 with a graphics screen 204 for the display of graphical and textual information, a key- 
board 206 for textual entry of information, a mouse 208 for the entry of graphical data, and a computer proc- 
essor 210. In this embodiment of the invention, the computer processor 21 0 contains program code to imple- 

45 ment the invention. The computer processor 210 is connected to the graphical display monitor 202, keyboard 
206, and mouse 208. Other graphical entry devices, such as a light pen (not shown), can be substituted for 
the mouse. This general purpose computer may be one of the many types well known in the art. such as a 
mainframe computer, a minicomputer, a workstation, or a personal computer. 

The invention will be described in four main sections as follows. First, a detailed description of the HAN 

50 language will be described in the section entitled TEXTUAL DESCRIPTION OF CIRCUITS. This section will 
describe the syntax of the language, and will describe how to specify the various circuit components using 
the language. 

The second section is entitled GRAPHICS TOOL. This section will describe the description of circuits using 
the graphics tool of the present invention instead of describing the circuits directly in the HAN language. 
55 The third section, entitled GENERATING AN FPGA IMPLEMENTATION FROM THE HAN DESCRIPTION, 

describes the generation of an FPGA implementation from the HAN language description. This section includes 
a description of the synthesis of circuit components into FPGA implementations. This section also includes a 
description of the various optimization techniques of the present invention. 
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The fourth section, entitled CIRCUIT DESIGN USING THE PRESENT INVENTION, gives an example of 
the design of a simple circuit using the present invention. The example illustrates the use of the HAN language 
to describe the circuit. The example also illustrates the alternative of using the graphics tool to describe the 
circuit. The example then shows the synthesis of the various components into an FPGA implementation. This 
5 section also illustrates several optimization techniques of the present invention. 



Textual Description of Circuits 

Users may describe the circuits they wish to implement by using the high-level application netlist (HAN) 
10 language. Using the HAN language and an input device such as the keyboard 206 of Fig. 2» users may specify 
a textual description of circuits using parameterized modules. The term parameterized module is used because 
each circuit component is described as a module and values are given to various parameters to desaibe the 
component. This will be clear from the following description of the HAN language. 

In HAN, a keyword starts with and all letters In a keyword are either upper-case or lower-case. In addi- 
15 tion. every keyword must be the first token of a line. 

A signal is an alphanumeric string starting with a character. A signal may contain the underscore ('_') char- 
acter A group of signals may be specified by using the form of an array. The syntax of a signal is: 

signal:: = name I name[num1: num2] 

In this description, and those following, the character" I " is used to indicate OR. In the form [num1:num2], 
both num1 and num2 are integers, where the first number is greater than the second number. For example, 
the following are valid signals: 

a 



20 



25 



sig_3 

mynet[5:0] 

In the above example. mynet{5:0] specifies a group of six signals: mynetS, mynet4, mynet3, mynet2, my- 
net1 and mynetO. 

A signal list is a list of signals separated by space(s). The signal list syntax Is: 
30 signaljist :; - signal I signal signaljist 

The following are examples of signal lists. 

a 

a b c 

mynet[7:0] xyz doutll 5:0] 

When specifying signals, the leftmost signal corresponds to the most significant bit (MSB) and the right- 
most signal corresponds to the least significant bit (LSB). 

In HAN, a circuit description starts with CIRCUIT and ends with .ENDCIRCUIT keywords. In general, a 
40 circuit description has the following syntax: 
' circuit ::= . CIRCUIT name 
preamble 
modules_spec 
.ENDCIRCUIT 

45 The preamble description Includes up to six fields that describe primary input/output signals, and has the fol- 
lowing syntax: 

1 preamble ;;= .PI signaljist 
. PO signal-list 
. PC signal-list 
50 . PB signaljist 

. PGR signal polarity 
.PI signaljist specifies all primary input signals. 

.PO signaljist specifies all primary output signals. .PC signaljist specifies alt primary clock signals. 

.PB signaljist specifies all primary bi-directional signals. .PGR signal polarity specifies the global reset signal. 

The .PGR field Indicates a global reset signal. The field indicates that when the specified signal gets the 
specified polarity ail storage elements will be reset. This global reset Is an asynchronous reset The syntax of 
the polarity field Is 

Polarity :: = HIGH I 1 I LOW I 0. In this polarity syntax, a HIGH specification is the equivalent of specifying 
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T. and a LOW specification is the equivalent of specifying "0". This polarity syntax applies throughout this 
description. 

If any of the above five preamble fields are not necessary, it can be omitted. For example, if a circuit does 
not have any primary bi-directional signal the .PB field would not be used. 
5 The modules_spec field of the circuit description describes ail the modules in a circuit. It has the following 

syntax: 

modu!es_spec:: = module_spec I modu!e_spec modules_spec 

The modules_spec field may be made up of one or more module_spec descriptions. The syntax of a mod- 
ule_spec description is as follows: 

module_spec :: = mem_module_spec I 
alu_module_spec I 
compare_module_spec I 
mux_module_spec I 
grp_mux_module_spec | 
reg_module_spec I 
shift_reg_module spec I 
counter_module_spec I 
tribuf_module_spec I 
fsm module spec I 

20 — ~ 

sub_circuit__module_spec 
The syntax and semantics of each module type are described below. 

Memory Module Specif ication 

Users can specify any size of memory through the use of a memory module. Users may also provide initial 
values of memories. The syntax of a memory module is shown below. 

mera_niodule_spec : : = 

30 .MKM name num_row num^col 

.ADDR signal_list 
.DIN sigTial_list 
.DOUT 3ignal_list 



35 

.WREN signal polarity 
.TRIEN signal polarity 

.INIT hexa_list 
. ENDMEM 

^ hexajist :: = hexa_decimal_number I hexa_decimal number, hexajist 

*^ 'Except for the .MEM and .ENDMEM fields, the order of fields does not matter. 

The .MEM field indicates the beginning of a memory module. It has three arguments. The first argument, 
name, is a symbol that shows the name of the memory. The second and the third arguments are integers. The 
45 second argument, num_row. specifies the number of rows, and the third argument. num_col. specifies the 
number of columns in the memory. The default values are 1 6 for the number of rows and 4 for the number of 
columns. 

The .ADDR argument is a list of address signals. 

The .DIN and .DOUT fields each have a signal list as its argument The number of signals in the .DIN 
50 and .DOUT fields must be the same as the number of columns of the memory. These fields specify the data 
in (DIN) and data out (DOUT) signals for the memory module. If the user-defined memory is used as a read 
only memory (ROM), the .DIN field must be absent 

The .WREN field specifies the write-enable signal, and it has two arguments. The first argument is a synv 
bol that shows the name of the write-enable signal. The second argument specifies the polarity of the signal. 
55 If it is 0 or LOW. the write-enable signal is active low; if 1 or HIGH, the signal is active high. The default value 
of this argument is 1. If this memory is used as a read only memory, there is no need to specify the .WREN 
field. 

The -TRIEN field is used if a user wants tri-state output from memory. This field specifies the control signal 
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of the tri-state buffer(s). The first argument of this field is the name of the control signal, and the second ar- 
gument is the polarity of the signal. If the control signal has the indicated polarity the memory module produces 
valid output. Otherwise, the memory module output is in a high impedance state. 

The .INIT field is used if a user wants to specify Initial contents of a memory. If this field is not specified, 
the initial value of the memory is unknown. If the number of columns in the memory Is less than or equal to 4, 
a sequence of hexa-decimal numbers is used for the initial values. The values are specified from left to right 
with the leftmost value being loaded into the highest memory location and the rightmost value being loaded 
into the lowest memory location. If the width of the memory location is 4 bits, then the binary equivalent of the 
specified hexadecimal value Is loaded into the memory location. For example, the specification: 

-MEM mem_modl 10 4 

-INIT 2468abcdef 
.ENDMEM 

would load the value "2", binary "0010", at location 9. and T, binary "1111", at location 0. 

If the number of columns of the memory is larger than 4, a sequence of parenthesized hexa-decimal num- 
bers is used to specify initial values. In this case, counting of bits is right justified. I.e., 4 bits from the right- 
end. 

For example, in the specification: 

.MEM mem_mod3 12 7 
. INIT 

(3, b) (2, a) (1,9) (0,8) (7,7) (6,6) (5,5) (4,4) (3,3) 

(2,2) (1,1) (0,0) 

.ENDMEM 



15 



20 



note that. In each pair, the first hex-digit is for the left (i.e., most significant) three bits and the second hexdigit 
30 is for the remaining four bits. The above example would load the binary value "0111011" into location 11, and 
the binary value "0000000" into location 0. 

ALU Module Specification 

35 Users can define ALU modules that perform data manipulation operations on input data. The general for- 

mat of an ALU specification is as follows: 

alu_module_spec : := 



40 



45 



.ALU name width 

.TYPE FADD | FSUB | FADDSUB signal 

.AIN signal_list 

. BIN signal_li9t 

.CIN HIGH I LOW I signal polarity 

.DOUT signal_list 
.COUT signal 
.ENDALU 



Except for .ALU and .ENDALU, fields of an ALU module specification can be In any order. 
50 The .ALU field indicates the beginning of an ALU module. It has two arguments. The first argument name, 

is a symbol that tells the name of the ALU. The second argument, width, is an Integer that indicates the width 
of the ALU. 

The .TYPE field shows the type of the ALU module. An ALU module can have one of three different types: 
FADD for adder; FSUB for subtracter; and FADDSUB for adder/subtracter. Users must specify a control signal 
55 when they use the FADDSUB ALU type. The ALU will work as an adder when the control signal is "high" or 1 ; 
it will become a subtracter when the signal is "low" or 0. 

The .AIN and .BIN fields indicate the two inputs of the ALU module. The number of signals in each field 
must be the same as the width of the ALU module. 
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The -CIN field describes a carry input signal. Its first argument can be HIGH (for logic 1), LOW (for logic 
0) or a signal name. When a signal name is used in the first argument, the second argument specifies the po- 
larity of the signal. If the polarity is 0. the carry input sig nal is inverted. The default value of the polarity argument 
is 1. 

5 The -DOUT field describes the output from the ALU module. For an ALU with the subtraction operation, 

the signals in the .DOUT field would have the result of the value of the .AIN signals minus the value of .BIN 
signals. 

The .COUT field indicates the carry output signal from the ALU module. 
10 Compare Module Specification 

The syntax of a compare module is as follows: 

cotnpare__module_spec : : = 

name width 
signal_list 
signal_list 

stat_type signal ( polarity ] 
UBIN I 2C0MP ] 
SUB I LOGIC ) 



where statjype ::= EG I GT I GE I LT I LE 

The brackets [ ) around the polarity argument in the .DTYPE and .IMPL fields indicate that the contents inside 
25 the brackets are optional. This use of brackets in module specifications, around field names and arguments, 
to indicate optional material, is used throughout this specification. 

The -CMP field indicates the beginning of a comparator module. The first argument, name, is the name of 
the module, and the second argument, width, is the width of the comparator module. 

The .AIN and .BIN fields show the Input signals to the comparator module. The number of signals in each 
30 field must be the same as the width specified In the .CMP field. 

The .OUT field allows users to describe the status signal. The first argument, statjype, specifies the type 
of status signal. There are five types of status signals: EQ {A = B), GT (A > B), GE (A >= 8), LT (A < B) and 
LE {A<= B). The second argument, signal, is the name of the output signal, and the last argument, polarity, is 
the polarity of the output signal. If the last field is omitted, the active-high polarity is assumed by default 
35 The .DTYPE field indicates the representation type of input data. The UBIN argument is used for unsigned 

binary representation, and the 2C0MP argument Is used for 2*s complement representation. If this field is not 
specified, the input data is assumed to be unsigned binary (UBIN). 

The .IMPL field specifies how this comparator will be Implemented. The SUB argument indicates that a 
subtracter will be synthesized for this comparison. If ".DTYPE 2C0MP" is used, the system will make use of 
40 a subtracter to implement a comparator. The LOGIC argument indicates that a tree of logic circuit will be syn- 
thesized. As a result, if ".DTYPE 2C0MP" and MMPL LOGIC are used at the same time in one comparator, 
* ^ the system will print an error message. If the .IMPL field is not specified, the synthesizer will make use of sub- 
tracters to implement the comparator. 

45 Multiplexer Module Specification 

The multiplexer module allows users to specify multiplexers of arbitrary width. The syntax of the multi- 
plexer module is as follows: 

50 mux_(nodule_3pec : : = 

.MUX name width 
.SEL signal_list 
.DIN number signal 



.CMP 
-AIN 
.BIN 
.OUT 

( . DTYPE 
[ . IMPL 
.ENDCMP 



.DOUT signal 
-OPT PERF I. AREA 
.ENDMUX 
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The .MUX field indicates the beginning of a multiplexer module. The first argument, name, indicates the 
name of the multiplexer. The second argument, width. Is an integer, and indicates the width of the multiplexer. 

The .SEL field specifies selection signals used by the multiplexer The leftmost signal is the most signif- 
icant bit. 

5 The first argument of the .DIN field, number, is an integer, and the second argument, signal, indicates an 

input signal. The first argument indicates the input location of its corresponding data input signal. The number 
of .DIN fields in one multiplexer module is the same as the width of the multiplexer. 
The .DOUT field specifies the name of the output signal of the multiplexer. 

The .OPT field indicates the goal of optimization for synthesis. PERF is for performance, and AREA is for 
10 area. If PERF is selected, the optimizer will synthesize the fastest FPGA implementation of the multiplexer. If 
AREA Is selected, the optimizer will synthesize a FPGA Implementation with the fewest number of components. 

An example of a 4-to-1 multiplexer, named "foo_m'*, is shown in FIG. 3. This multiplexer is described in 
HAN as follows: 
. MUX foo_m 4 
15 . SELs1 sO 

.DIN 3 d1 
. DIN 2 c1 
. DIN 1 b1 
- DIN 0 a1 
20 . DOUT m1 

. ENDMUX 

Group of Multiplexers 

25 The syntax for the specification of a group of multiplexers Is as follows: 

grp_mux_module_spec ::= 

.GRMUX name num_mux width_of _one_mux 
.SEL signal_li3t 
30 -DIN number signal^list 

. DOUT signal_list 
.OPT PERF I AREA 

.ENDGRMUX 

35 The .GRMUX field indicates the beginning of a multiplexer-group module. The first argument, name, is the 

name of the module, the second argument num_mux. Is the number of multiplexers in this group. The last ar- 
gument, width_of_one_mux Is the number of Inputs of each multiplexer. All component multiplexers have the 
same width. 

The .SEL field indicates selection signals of a component multiplexer. 
40 The .DIN field specifies the data input signals to the multiplexers. There must be N .DIN fields, where N 

- is the width of a component multiplexer. The first argument, number. Is the number Indicating input position. 
The second argument, signaljist. is a list of signals e.ach of which Is connected to the specified input position 
of each component multiplexer. There must be M signals in the list, where M Is the number of multiplexers in 
the group. 

45 The .DOUT field indicates output signals from all component multiplexers. There must be M signals in the 

argument. 

The .OPT field Indicates the optimization goal when this group of multiplexer Is synthesized. PERF Is for 
performance, and AREA Is for area. 

One example of a multiplexer group, named "foo_g", consisting of four 2-to-1 multiplexers, is shown in FIG. 
50 4. All four multiplexers 402, 404, 406, 408 share the same selection signal, "selO". This multiplexer Is described 
In HAN as follows: 

. GRMUX foo_g 4 2 
. SELselO 
. DIN 1 A[3:0] 
55 . DIN 0 B(3:01 

. DOUT Y[3:0] 
ENDGRMUX 
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Register Module Specification 

Users can specify registers of arbitrary width. They can also select the clocking scheme of registers. The 
following is the format for register module specification: 

5 

reg_module_sp€C : : = 

. REG name width 

.CK clock_mode clock_signal (clock_enable_s ignal 

polarity) 
.DIN 3ignal__list 

10 



.DOUT signal^list 

( .RESET reset_mode reset_signal reset_value } 
. ENDREG 

15 

Except for .REG and .ENDREG fields, the order of fields does not matter. 

The .REG field indicates the beginning of a register module. The first argument, name, specifies the name 
of the register module. The second argument, width, specifies the width of the register module. 

The -CK field specifies the clock of this register. The first argument, clock_mode, shows the clocking mode. 
20 The syntax of this argument is as follows: 

clock_mode :: = LEVEL_HIGH I LEVEL_LOW I EDGE_HIGH I EDGE_LOW 

LE\/EL_HIGH indicates the register is level sensitive, and dock is active high. LEVEL_LOW indicates the reg- 
ister is level sensitive, and clock is active low. EDGE_HIGH indicates the register is edge triggered at the rising 
edge of the clock. EDGE_LOW indicates the register is edge triggered at the falling edge of the clock. 

The second argument, dock_signal, indicates the name of the dock signal. The third argument, 
clock_enable_signal, specifies the signal used as the clock-enable. If this argument is ignored, the dock is 
always enabled. The last argument, polarity, specifies the polarity of the dock_enable signal. If this is not spe- 
cified, the dock_enable signal is active-high by default. 

The .DIN field spedfies a list of input signals to the register. The .DOUT field spedfies a list of output sig- 

30 

nals from the register. 

The .RESET field shows the reset mechanism of the register. The first argument, reset_mode. specifies 
the reset mode, and its syntax is: 

reset_mode :: = SYNC_HIGH I SYNC_LOW I ASYNC_HIGH I ASYNC_LOW 

35 SYNC_HIGH indicates synchronous reset when the reset signal is high. SYNC_LOW indicates synchronous 
reset when the reset signal is low. ASYNC_HIGH indicates asynchronous reset when the reset signal is high. 
ASYNC_LOW indicates asynchronous reset when the reset signal is low. 

The second argument, reset_signal. spedfies the reset signal. The last argument, reset_value, is a string 
of bits (0 or 1) that specifies the value of the register when it is reset. The leftmost bit is for the MSB and the 

40 rightmost bit is for the LSB. If the reset_value is not specified, a default value of all O's is used. 

L'^^-^ Shift Register Module Specification 

Users can spedf y shift registers of arbitrary width. The following is the format for spedf ying a shift register 
45 module. 



shif t_reg_module_spec 



50 



55 



.SHREG 
( .TYPE 
.DIR 
[ .PLOAD 
[ .MSBIN 
[ .LSBIN 
[ .DOUT 
t.MSBOUT 
[ .LSBOUT 



name width 
LOGIC I ARITH | CIRCULAR ] 
RIGHT|LEFT|BIDIR signal 
load_signal polarity signal_list, ] 
HIGH I LOW I signal ] 



HIGH j LOW [signal 
signal^list ] 
signal ] 
signal ] 



.CK clock_mode clock_signal ( clockenable_3 ignal polarity] 
t .RESET reset_mode reset_signal reset^value ] 
. ENDSHREG 
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The .SHREG field indicates the beginning of a shift register module. It has two arguments. The first, name, 
indicates the name of the shift register module. The second, width, specified the width of the shift register 
module. 

The .TYPE field specifies the type of the shift register module. The following table shows the operation 
5 of a shift register of each type. (For an N bit register, bit N - 1 is the MSB and bit 0 is the LSB.) 



Shift Right 



Shift Left 



LOGIC MSB <- MSB input signal LSB <- LSB input signal 

^0 or 0 or 0 

Bit i <- Bit(i + 1) Bit i <- Bit(i-l) 



15 



ARITH 



CIRCULAR 



MSB is unchanged. MSB is unchanged. 

(MSB-1) <- MSB LSB <- 0 

Bit i <- Bit<i + 1) Bit i <- Bit(i-l) 



MSB <- LSB 

Bit i <- Bit ii^l) 



LSB <- MSB 

Bit i <- Bit (i-1) 



20 The .DIR field specifies the direction (i.e., right or left) of shift. If the argument specifies RIGHT, then the 

register is shift right only. If the argument specifies LEFT, then the register is shift left only. If the argument 
specifies BIDIR. then the shift direction is determined by the value of the signal. If the signal value is HIGH 
or 1, it is shift right; otherwise, shift left. 

The .PLOAD field describes parallel load infonmation. The first argument. load_signal, indicates a LOAD 

25 signal. The second argument, polarity, indicates when the loading operation takes place. The third argument, 
signaljist, is a list of parallel input signals. For example, if polarity is HIGH, the shift register gets the value 
of the parallel input signals when the LOAD signal is high and the clock signal is activated. Note that the number 
of signals in the third argument must be the same as the width of the shift register. 

The .MSBIN field indicates either HIGH, LOW, or the serial input signal to the most significant bit position. 

30 If the type of shift register is LOGIC and if shift direction is RIGHT, the MSB of the shift register will have the 
value HIGH, LOW. or the value of the specified signal after a clock. If this field is not specified, the value 0 is 
used as a serial input 

The .LSBIN field indicates either HIGH, LOW, or the serial input signal to the least significant bit position. 
If the type of the shift register is LOGIC and if shift direction is LEFT, the LSB of the shift register will have 
35 the value HIGH, LOW, or the value of the specified signal after a clock. If this field is not specified, value 0 is 
used as a serial input 

The .DOUT field shows parallel output signals of the shift register. The number of signals in the argument 
must be the same as the width of the. shift register. 

The .MSBOUT field indicates the signal name of the MSB of the shift register. The .LSBOUT field indicates 
40 the signal name of the LSB of the shift register. Ashift rBgister module must have at least one of .DOUT, .MSBOUT 
or .LSBOUT fields. 

' The .CK field specifies the clock of this register. The first argument, cIock_mode. shows the clocking mode. 

The user may choose one of two modes: EDGE_HIGH indicates the register is edge triggered at the rising 

edge of the dock; and EDGE_LOW indicates the register is edge triggered at the falling edge of the clock. The 
45 second argument. clock_signal. indicates the name of the clock signal. The third argument. 

clock_enable_signal, specifies the signal used as clock-enable. If this argument is ignored, the clock is always 

enabled. The fourth argument is the polarity of the clock-enable signal. 

The .RESET field indicates the reset mechanism of the register. This field is as described in connection 

with the register module. 

50 

Counter Module Specification 

Users can specify up-, down-, or up/down counters of various widths. They can also specify a parallel load- 
able counter. The following is the format for a counter module specification. 

55 
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count er_module_s pec ::= 
. COUNTER • 



name width 

UP I DOWN I UPDOWN signal 
load_signai polarity signal_list 
signal_list 
signal 

clock_mode clock_signal 
[clock_enable_signaI polarity ] 
reset_mode reset_signal [reset_value ] 



.CTYPE 

.PLOAD 

.DOUT 

.COUT 

.CK 



.RESET 

. ENDCOUNTER 



10 

! 

15 

I 

j 

20 



I 

30 

I 35 

I 

I 

40 



50 
55 



The .COUNTER field indicates the beginning of a counter module. The first argument, name, indicates the 
name of the counter module. The second argument, width, indicates the width of the counter module. The .CTY- 
PE field indicates the type of the counter. The counter may be an UP counter, a DOWN counter, or an UPDOWN 
counter. If the UPDOWN type is specified, the last argument of this field specifies the control signal that con- 
trols the direction of the counter module. If the signal is 0, the counter is an UP counter; if the signal is 1 , the 
counter is a DOWN counter. If UP or DOWN type is used, the last argument is skipped 

The .PLOAD field represents the parallel-load capability of the counter. If this field is not included, the 
counter does not load parallel input data. The first argument, load_signal, indicates the load control signal. The 
second argument, polarity, indicates the effective polarity of the load control signal. The last argument, sig- 
naljist, is a list of signals that are connected to toad inputs. When the load and clock signals are activated, th 
counter gets its values from the list of signals. 

The .DOUT field specifies a list of output signals from the counter. The .COUT field specifies the carry 
output signal from the counter. The carry signal will be high during the clock perio in which all outputs are '1'. 

The .CK field specifies the clock of a counter module. This field is as described in connection with the reg- 
ister module. 

The .RESET field specifies the reset mechanism of the counter. This field is as described in connection 
with the register module. 

Tri- state Buffer Specification 

Users can specify tri-state buffers. The following is the syntax for specifying a set of tri-state buffers. 
tribuf_module_spec ::= 
. TBUF name number 
. ENABLE signal polarity 
. DIN signaljist 
. DOUT signaljist 
. ENDTBUF 

The .TBUF field indicates the beginning of a tri-stat|s, t)uffer module. The first argument, name, indicates 
the name of the tri-state buffer nrK>dule. The second argument, number, indicates the number of buffers in the 
tri-state buffer module. 

The .ENABLE field describes the enable signal of the buffer(s). The first argument, signal. Indicates the 
name of the enable signal. The second argument, polarity, specifies whether the tri-state buffer is active high 
or active low. The default value of the polarity argument is 1. 

The .DIN field describes the data input signals of the buffers. The .DOUT field describes the data output 
signals of the buffers. 

Finite State Machine Specification 

Users can specify finite state machines. The syntax for specifying a finite state machine is: 
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f sm_module_spec : 
-FSM 



10 



15 



. IN 

. COMBOUT 
.REGOUT 
. STATE 
-CK 

.RESET 
.EQS 



.TRANS 



. ENDFSM 



reset state 



name 

signal_list 
signal_list 
signal_list 
state_list 

clock_mode clock_signal 
reset_inode reset_signal 
number_of ^entries 
/* one equation per line 
/* each equation has var 
number_of _entries 
/* one transition specification per line */ 
/* each transition specification has the */ 
/♦format of ♦/ 

/♦ statel state2 expression ♦/ 



expression format */ 



The .FSM field indicates the beginning of a finite state machine module. Its argument name, is the name 
of the FSM. 

20 The .IN field describes the input signals of the FSM. Clock and reset signals must not be included here. 

The .COMBOUT field specifies the output signals that are produced by the FSM, but are not registered 
by extra flip-f lop(s). In general, output signals from FSMs belong to this category. 

The .REGOUT field indicates output signals of this FSM that must be registered. That is, an additional flip- 
flop (other than those for the finite state machine) must be used for each output signal of this type. 
25 The .STATE field shows the names of states of the FSM. Only flip-flops are used to implement states of 

FSMs. The .STATE field must appear before .RESET, .EQS and .TRANS fields. A state name must be unique 
in a circuit or sub-circuit description. 

The .CK field describes the clock signal and its type. The clock_mode and clock_signal fields are as de- 
scribed in connection with the register module. 
30 The .RESET field shows the reset signal and the reset state of the FSM. The reset_mode and reset_signal 

are as described in connection with the register module. The reset_state indicates the state of the FSM when it is 
reset. When the reset signal is activated, the finite state machine will go to the state specified as reset_state. 
The .EOS field contains a set of Boolean equations, one per line. Each Boolean equation has the format 

of: 

35 Variable = Expression 

Equations in this field may specify output variables of this FSM. They can also specify temporary variables 
being used in the FSM. The detailed format of the equation is described below (in "Boolean Equation Speci- 
fication** section). V* ' ; 

The .TRANS field contains a set of state transition functions, one per line. Each state transition has the 
40 following format; 

' present_state next_state expression 

For example, consider an FSM with three states (S1 502, S2 504 and S3 506) as shown in Fig. 5. The 
machine has two input signals, a and b. The state transition of the machine is represented as follows: 

45 

.TRANS 4 



50 



SI 


S2 


a 


S2 


S3 


b 


S3 


82 


a 


S3 


SI 


la*b 



Random Logic Description 

In addition to data path modules, users can also specify random logic in the HAN language. Users may 
specify combinational functions and flip-flops. 

The syntax for a random logic circuit description is: 

random J ogic_spec :: = bfunc_spec I ff_spec 
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A Boolean function may be specified with Boolean equations or Cube format 
The syntax for a Boolean function specification is: 

bfunc_spec :: = bfunc_eq I bfunc_cube 



Boolean Equation Specification 



If the user wants to specify a boolean function using boolean equations, the format is: 

bfunc_eq :: = .BEQ signal = expression 

The following operators are supported for boolean expressions. 



Symbol 



Meaning 




logical 
logical 
logical 
logical 



negation 

and 

or 

exclusive-or 



Parenthesis can be used to change the order of evaluation. 

For instance, to describe a logical AND gate with three inputs (a, b and c) and one output (y). the following 
boolean equation is used: 
.BEQ y = a*b*c 

Cube Specification 

If the user wants to specify a boolean function using CUBE format, the format is: 



The .CUBE field indicates the beginning of the CUBE module. The argument, signal, indicates the output 
signal. 

The .IN field indicates the input signals. 

The .TBL field describes the boolean function. The number of columns in the table is the number of input 
signals plus one. Each column represents a corresponding input signal. For example, a "1" in the first column 
of the table represents the active state of the first input signal. A "0" represents the inactive state of the signal. 
The last column in each row indicates the output signal with the specified combination of input signals. There 
may be more than one row in the table. Each row indicates a combination of active and non-active states of 
the input signals and the corresponding state of the output signal. 

For example, to describe a logical AND gate with three inputs (a, b, and c), and one output (y), the following 
CUBE format is used. 



bfunc cube 



.CUBE signal 

.IN 9ignal_list 

.TBL 

/♦ Cube content one per line */ 
.ENDCUBE 



.CUBE y 
. IN 



a b c 



.TBL 



111 1 
.ENDCUBE 



Specifying Flip-flops 



The invention supports the following construct to represent a flip-flop. 
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f f_spec : : a 

. FF name 
-DIN signal 
.DOUT signal 
5 -CK clock_mode clock_signal 

(clock_enable_3ignal enable^polarity ] 
-RESET resetmode reset_signal reset_value 
.ENDFF 

10 The .FF field indicates the beginning of a flip-flop specification. Its argument is the name of the flip-flop. 

The .DIN field specifies the input signal to the flip-flop. The .DOUT field specifies the output signal of the 
flip-flop. 

The .CK field specifies the dock of the flip-flop. This field is as described in connection with the register 
module. 

15 The .RESET field shows the reset signal and the reset value of the flip-flop. The reset_mode and reset_sig- 

nal fields are as described in connection with the register module. The reset_value indicates the state of the 
flip-flop when it is reset. 

The .ENDFF field indicates the end of the flip-flop description. 

20 Subcircuit Specification 

Users can mal^e use of sub-circuits in a circuit specification, thereby allowing hierarchical description of 
circuits. The following is the syntax of specifying a sub-circuit. 

25 

sub_circuit_module spec ::= 
.SUBCKT name 
-REFNAME name 
.IN signal_list 
.OUT signal_list 
30 (.BI signal_list ] 

[.CK signal_list ] 
. ENDSUBCKT 

The .SUBCKT field indicates the beginning of a sub-circuit module. Its argument tells the name qf the sub- 
35 circuit module. 

The .REFNAME field shows the name of the actual circuit that is referred to by this subcircuit. Its argument 
is the name of the referred circuit. 

The .IN field shows a list of input signals to the sub-circuit These signals are matched to primary input 
signals of the referred circuit based on position. 
40 The .OUT field indicates a list of output signals from the sub-circuit Again, these signals are matched to 

* tu; primary output signals of the referred circuit based on position. 

The .BI field describes a list of bidirectional signals to/from the sub-circuit. These signals are matched to 
primary bidirectional signals of the referred circuit based on position. 

The .CK field shows clock signal(s) to the sub-circuit. As before, these signals are matched to primary dock 
45 signals of the referred circuit based on position. 

The above sub-circuit definition allows users to have a hierarchical description of their application circuits. 

Graphics Toot 

50 As an alternative to entering circuit descriptions using the HAN language, users may describe circuits using 

a graphics tool. The graphics tool will translate a user's graphical description of a circuit into the HAN language. 

The graphics tool is a window type environment. The graphics tool displays a window type editor on the 
graphical display screen. As shown in FIG. 6. the layout of the window 600 consists of three horizontal bands 
at the top 602, 604, 606, a relatively large canvas area below the three bands on the left side of the tool 608, 

55 and a smaller panel area below the three bands on the right side of the tool 610. The panel area contains several 
icons representing design elements (or modules) such as a register 611, a memory 612, an ALU 613, a tri- 
state buffer 614, a counter 615, a finite state machine 616, logic 617, a decoder 618, parity 619. a shift register 
620. a multiplexer 621 , a multiplexer group 622, a comparator 623. an accumulator 624, and primary I/O 625. 
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The horizontal band 602 located at the top of the window is the title area. This area indicates the tool's 
name. 

The horizontal band 604 below the title area 602 is the nnessage area. The message area informs users 
of the status of operations which they requested of the graphics tool. For example, if a user executes a request 
5 to save the work done on the screen into a file, the message area will display a message indicating whether 
the operation was successful or not. If a user selects an object from the canvas area 608. the message area 
will display the type of that object (e.g. register, ALU, etc.). 

The third horizontal band 606 is the pulldown menu bar. This area consists of several rectangular regions 
with text inside. These regions may be command buttons. Positioning the mouse glyph on top of one of these 
10 and pressing the mouse button will cause the action indicated by the text to occur immediately. Other regions 
may be pulldown menus. Positioning the mouse glyph on top of one of these and pressing the mouse button 
will cause a menu to drop down. Dragging the glyph over one of the menu selections will cause that selection 
to darken. If the mouse button is released, the action associated with the selection will be taken. 

The larger rectangular region below the pulldown menu bar is the canvas area 608. This is where the user 
75 will do design work. 

In order to add a design element using the graphics tool, first, the element to be added is selected by pos- 
itioning the mouse glyph on an icon in the panel area 610 and pressing the mouse button. Whichever was se- 
lected becomes the current design element. The second step is to place the element on the canvas area 608. 
This is done by positioning the mouse glyph somewhere in the canvas area 608 and pressing the mouse button. 

20 The selected design element will appear in the canvas area. Any combination of elements may be used to con- 
struct the circuit. Any element may be repositioned on the canvas area by positioning the mouse glyph over 
that icon, pressing the mouse button and dragging the icon to a new position. When the mouse button is re- 
leased, the element will remain in the new position. Elements may be deleted by pressing the DELETE key 
on the keyboard, moving the mouse glyph over the element to be deleted, and pressing a mouse button. The 

25 item will disappear. 

Once design elements have been placed into the canvas area 608, attributes may be assigned to them. 
For example, a REGISTER may be a design element, and 4-bit width might be an attribute which has been 
chosen for the register. The input and output signals are also attributes which may be assigned to design ele- 
ments. The first step in this process is to select the element whose attributes are to be edited by positioning 

30 the mouse glyph on the element of interest and double-clicking the mouse button. A message is displayed in 
the message area 604 indicating which type of item has been selected. Next, the edit function is selected from 
the appropriate menu on the pulldown menu bar 606. 

A multibox 630 will appear with various fields for which the user may specify values. This box will be dif- 
ferent depending on the type of element A multibox for a Register module is shown at 630. The multibox 

35 prompts the user for the attributes of the selected design element In the example shown, the multibox prompts 
the user for the register attributes Name. Width, Inputs, Outputs, Clock and Reset. These attributes correspond 
to the fields and arguments required in the HAN language description of a register module. For each predefined 
design element, a corresponding multibox will be used to enter the attributes of that design element Attributes 
may be added'to all the chosen design elements in this-manner. 

40 If the input to one element is the output of another, the graphics tool will automatically draw a directed arc 

between them indicating this data dependency. For example, in Fig. 6, the output of CNT1 650 is an input to 
MEM1 656. The graphics tool automatically displays a directed arc 654 on the screen to indicate this relation- 
ship. 

If the user prefers to see a more informative view of elements which has the name, inputs, and outputs. 
45 the user may select the appropriate command from the pulldown menu bar. This will display the design ele- 
ments as shown in Fig. 7. For example, in this view, COUNTER CNT1 is shown as a box 702 including infor- 
mation on the name, type, inputs, and outputs of the element A similar view is displayed for MEMORY MEM1 
704 and REGISTER REG1 706. 

Users may also change the form of the connecting lines between design elements. By choosing an ap- 
50 propriate command from the pulldown menu, the user may change the form of the connecting lines from the 
directed arc 654 shown in Fig. 6, to the undirected (wide) line 708 as shown in Fig. 7. 

Figures 6 and 7 will be discussed in more detail in connection with the example circuit discussion in the 
section entitled CIRCUIT DESIGN USING THE PRESENT INVENTION. 

In using the graphics tool, a designer may not only use pre-defined elements, but may also define a macro 
55 from a collection of elements, or may derive a new objectf rom the pre-defined elements. If the designer choos- 
es to define a new element, a new icon may be created. The macro definition and object derivation aspects 
of the invention are described in connection with Fig. 8. 

When the designer chooses a design element icon step 802, the graphics tool determines whether the ol>- 
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ject chosen is a pre-defined design element in step 804. If it is pre-defined, the system asks the designer for 
the attributes of the design element In step 806, as described above. If it is determined in step 808 that there 
are more objects in the design, the system returns to step 802 and the designer may add more elements to 
the design. 

5 If the element chosen by the designer Is not predefined, the system determines whether the user wants 

to define a macro or derive a new design element in step 810. If the designer wishes to define a macro, the 
system continues to step 812. A designer can group a collection of design elements and call them a macro, 
which can then be used in a design. Arbitrary fields in the underlying design elements can be tagged as either 
constant or variable. If tagged as variable, when the object is chosen for use in a design, the multibox requesting 

10 attributes will request attributes for these variables. If an attribute is tagged as constant, a value is assigned 
to the attribute during macro definition step 812 and no field appears for it In the multibox. After the user has 
defined the macro, a template is created In step 814. This defined macro can then be used by the designer 
as any other pre-defined design element The system will then query the variable attributes for this macro as 
used In the current design In step 806. 

15 If the element chosen by the designer Is not predefined, the user may derive a new type of design element 

in step 816. The graphics tool permits the derivation of new object types from the already provided atomic 
types. For example, an ALU Is a systenrvdefined atomic type. It defines several parameters which can be set 
by the designer including width and type (e.g. adder, subtracter, etc.). A designer who frequently uses an 8- 
bit adder can "derive" a new object from the ALU type with the type parameter set to adder and the width set 

20 to 8. After the designer has defined the new design element, a template is created in step 814. A unique Icon 
can be associated with this derived type and the designer can henceforth use it as a pre-defined object When 
the designer chooses to use this new type, the multibox which queries attributes will request attributes for all 
of the parameters normally associated with the ALU object except for the type and width fields. It Is a unique 
capability of the interface to allow the object-oriented concept of object derivation to be extended to the end- 

25 user via a graphical interface. 

The notion of derived design elements implies the creation of a design element hierarchy. Element deriv- 
ation is a powerful concept because it employs the notion of attribute Inheritance. Since a derived design ele- 
ment inherits all of the parameters and attributes of its parent design element, it permits the creation of a cus- 
tom design-element library with less work, in many cases, than the macro approach. 

30 When the designer has completed the design using the graphics tool, the result of condition 808 will be 

"N" and the system will translate the graphical representation of the circuit into the HAN language in step 818. 
This HAN language is then used as the input to the.compiler/optimizer. 

Generating An FPGA Implementation from The HAN Description 

35 

The compiler/optimizer reads input in the HAN format and produces technology-mapped FPGA descrip- 
tions. The operations of the compiler/optimizer will be explained in connection with the ORCA FPGA of AT&T, 
discussed above. However, the techniques described below can be adapted to other FPGA chips from other 
manufacturers, and the ORCA FPGA chip is being used here for illustrative purposes only. 

40 

-^r^ Functionality of one PLC of ORCA FPGA 

As discussed above, a logic cell of the ORCA FPGA is called a programmable logic cluster (PLC). There 
are hundreds of PLC's in one ORCA FPGA chip. As shown In Fig. 9, one PLC. 902, contains four lookup tables 
45 (LUTs) 904. 906. 908, 910, each of which is a 16-bit static RAM (random access memory). It also contains four 
(edge-triggered) flip-flops 912,914,916,918 which can also be configured as (level-sensitive) latches. A PLC 
also contains configurable connection blocks, 920 and 922. 

One PLC of ORCA FPGA can implement the following circuits: one 1 6x4 memory, or two 16x2 memories; 
a 4-bit adder or subtracter or adder/subtracter; a 4-bit counter up. down, up/down, parallel load; a 4-bit register; 
50 a 4-blt tri-state buffers; and certain logic circuits. One PLC can implement certain combinations of the above 
functions. 

For each user-defined module, the compiler/optimizer will produce an optimized design including config- 
ured PLC's and the connections among the PLC's, as explained below. The resulting design is also called a 
netllst of PLC's. 

55 A flow diagram of the operation of the compiler/optimizer is shown in Fig. 10. The HAN description repre- 

sented at 1002. which is created by either entering the HAN language textually, or by using the graphics tool 
to create the HAN language, is read by the compiler/optimizer. The compiler/optimizer first reads the input/out- 
put signals from the HAN description in step 1004. The compiler/optimizer then reads a parameterized module 
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in step 1006, and saves the module and the signals connected to it in step 1008. If there are more modules to 
read from the HAN description then the result of condition 1 01 0 is yes and the compiler/optimizer will read the 
next parameterized module in step 1006. This process continues until there are no more modules to be read. 
When all modules have been read, the compiler/optimizer performs phase 1 optimization step 1012. 

5 

Phase One Optimization 

Phase 1 optimization will be described in connection with Fig. 11. First, all storage elements in a circuit 
(e.g. registers, shift-registers, counters, finite state machines, and subcircuits) are analyzed in step 1102. If 

10 all the storage elements in a circuit use the same asynchronous reset signal and if the polarity of the reset 
signals are the same, then the local reset signals are replaced by a global (chip-wide) reset signal of the FPGA 
Chip in step 1104. With respect to finite state machines, if a finite state machine has a starting state and if the 
starting state is triggered by an asynchronous reset signal, the optimizer/compiler adds the reset signal to the 
preset port of a flip-flop corresponding to the starting state. 

15 The optimizer/compiler next checks signal polarities of adjacent modules in step 1106 and changes the 

polarities in step 11 08 if such changes result in more efficient implementation. For example, consicJer the circuit 
in Fig. 12, which contains an 8-bit comparator 1202 and an 8-bit shift register 1204. The shift register 1204 
loads its input data C[7:01 1206 if its L/S' signal 1208 is high; it shifts its contents when the signal is low. Using 
AT&T's ORCA FPGA, an 8-bit equality checker can be implemented using two PLC's if the equal output is ac- 

20 tive-low. If the output is active-high an inverter must be added, which results in an additional PLC. In this case, 
the optimizer/compiler would change the polarity of the L/S' signal 1208 of the shift register 1204 to active- 
low, and it will synthesize the shift register accordingly. As a result, one less PLC would be required to imple- 
ment the circuit 

Refen-ing back to Fig. 1 0, after the phase 1 optimization step 101 2 is complete, the next step 1014 is mod- 
25 ule synthesis and technology mapping. In this step, each module which is described in the HAN language is 
synthesized into one or more PLC's of the FPGA. 

Module Synthesis 

30 Compiling Memory Modules 

The optimizer/compiler compiles each user-defined memory to one or more PLC's. If the total number of rows 
of a user-defined memory is larger than 16, the optimizer/compiler introduces an address decoding circuit and 
tri-state buffers. For example, consider a user-defined memory of 32 rows and 4 columns as shown in Figure 

35 13A as 1302. This memory module must be split into two 16x4 memory units for ORCA FPGA implementation 
because, as discussed above, each PLC can implement one 16x4 memory. The optimizer/compiler produces 
a compiled circuit as shown in Fig. 13B, and allocates Ihree PLCs 1304, 1306, and 1308 for the circuit One 
16x4 memory 1310 and four tri-state buffers 1312 are assigned to PLC 1306, and one 16x4 memory 1314 

' and four tri-state buffers 1 31 6 are assigned to PLC 1 308. Two gates 1 32Q;and 1 322 are assigned to PLC 1 304. 

40 Note that the optimizer/compiler makes use of programmable polarity of tri-state enable signals in ORCAs 
PLC. For the PLC implementing the upper half memory 1306, it uses an active-high a4 signal 1324. For the 
PLC implementing the lower half memory 1308. it uses an active-low a4* signal 1326. 

Compiling ALU And Counter Modules 

45 

The optimizer/compiler compiles each user-defined ALU into one or more PLCs. If the width of a user-defined 
ALU is larger than 4, the optimizer/compiler introduces carry signals between PLCs. As an example, consider 
a 10-bit user-defined adder shown in Fig. 14A. The name of the adder is "foo". and it has the Ci signal 1402 
as its carry input, and Co signal 1404 as its can-y output It has 2 10-bit inputs (a9-a0 and b9-b0) and one 10- 

50 bit output (y9-y0). For this circuit, the optimizer/compiler produces a three PLC 1406. 1408, 1410 implemen- 
tation as shown in Fig. 14B. PLC 1406 implements a 2-bit adder 1416 and PLC's 1408 and 1410 each imple- 
ment one 4-bit adder 1418. 1420. Adder 1416 has two 2-bit inputs, (a9-a8 and b9-b8) and one 2-bit output 
(y9-y8). Adder 1418 has two 4-bit inputs (a7-a4 and b7-b4) and one 4-bit output (y7-y4). Adder 1420 has two 
4-bit inputs (a3-a0 and b3-b0) and one 4-bit output (y3-y0). The optimizer/compiler introduces two new can-y 

55 signals bet ween the PLC's: foo_d 141 2 and foo_c2 141 4. 

The optimizer/compiler would implement counters in a similar manner and would introduce intemnediate 
carry signals. 

In addition, the optimizer/compiler introduces a new reset circuit if necessary. Consider, for example, an 
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11 bit counter 1502 shown in Fig. 15A. It is clocked by CKO signal 1504; it has Co 1506 as its carry output 
signal, and Qio, Qg^ Qa, Q7. Qe. Q5. Q4, Q3. Q2. Qi. Qo as data output signals. 

Since one PLC of ORCA FPGA can innplement a 4-bit cou nter, the optimizer/compiler allocates three PLC's 
1 550, 1 552, 1 554 as shown in Fig. 1 5B. In addition, it Introduces a new circuit, a 3-input AND gate 1 556, whose 
5 input comes from Qa, Q9 and Q10 of 1554. The output of the AND gate is used as a (synchronous) reset signal 
of the most significant counter 1554. It is also used as a carry output signal C© 1558. 

Compiling Multiplexer Modules 

10 The optimizer/compiler compiles each user-defined multiplexer into lookup table(s). Consider, for example, 

a 4-I0-I multiplexer as shown in Fig. 16A. The multiplexer has four input signals (a, b, c, and d) and two selection 
signals (si and sO). Since, the total number of inputs of the multiplexer is 6, the optimizer/compiler allocates 
all four lookup tables in one PLC 1602 (i.e., 64-bit RAM in total) to implement the multiplexer. Alternatively, the 
optimizer/compiler could allocate only three lookup tables for the multiplexer. This is shown in Fig. 16B. Each 

15 2-to-1 multiplexer 1604. 1606, 1608 is implemented by one 16-bit lookup table. This three PLC 1610, 1612, 
1614 implementation would result in more signal delay than the implementation in Fig. 1 6A. The optimizer/conn- 
piler would implement the 4-to-1 multiplexer according to the user's request represented in the .OPT field of 
the multiplexer module specification. 

If PERF was chosen, then the optimizer/compiler would implement the 4-to-1 multiplexer as shown in Fig. 

20 16A. If AREA was chosen, the optimizer/compiler would implement the 4-to-1 multiplexer as shown in Fig. 168. 

As another example, consider an 8-to-1 multiplexer shown in Fig. 17. This multiplexer has eight input sig- 
nals (a-h) and 3 select signals (sO, si, s2). This multiplexer can be implemented in many different ways, three 
of which are shown in Figs. 18-20. Each of the three implementations uses two PLCs. 

The first implementation. Fig. 1 8. uses only lookup tables. Each 2-to-1 multiplexer 1802, 1804, 1806, 1808. 

25 1810, 1812. 181 4 is implemented by one 16-bit lookup table. This implementation requires 2 PLC's 181 6. 1818. 
The other two implementations use tri-state buffers as well as lookup tables. 

The implementation of Figure 19 uses 2 PLC's 1902, 1904 to implement the 8-to-1 multiplexer. PLC 1902 
uses three lookup tables to implement three 2-1 multiplexers 1906, 1908, 1910, and two tri-state buffers 1912. 
1914. PLC 1904 uses two lookup tables to implement two 2-to-1 multiplexers 1916, 1918. and two tri-state 

30 buffers 1920, 1922. 

The implementation of Fig. 20 uses 2 PLC's 2002. 2004 to implement the 8-to-1 multiplexer. PLC 2002 
uses four lookup tables to implement a 4-to-1 multiplexer 2006, and a tri-state buffer 2008. PLC 2004 uses 
four lookup tables to implement a 4-to-1 multiplexer 2010, and a tri-state buffer 2012. 

Assuming that the routing delay between PLC's is equal in Figs. 18-20, the implementation in Fig. 20 is 
35 the best, since its signal delay is the smallest and each PLC has a small number of external connections. The 
implementation in Fig. 18 is the worst because it has the longest signal delay. Since all three implementations 
(Figs. 18-20) use the same number of PLC's, the optimizer/compiler uses the implementation in Fig. 20. re- 
" gardless of the specification in the .OPT field of the multiplexer module specification. 

40 Compiling Finite State Machines 

For the finite state machine (FSM) module, the optimizer/compiler uses a one-hot encoding scheme. That 
is. the optimizer/compiler produces N flip-flops, where N is the number of states of the FSM. The optimiz- 
er/compiler synthesizes a circuit such that only one flip-flop (among the N flip-flops) has the value of '1' at any 
45 given time. If a user specified a reset state, the optimizer/compiler produces a circuit that forces the flip-flop 
which corresponds to the reset state to have the value '1* when the reset signal is activated. 

The optimizer/compiler performs similar synthesis operations for other modules. In view of the teachings 
of this specification, the synthesis of the other electronic circuit design modules can be readily implemented 
by one skilled in the art. Therefore, a detailed description of the synthesis of each module is not given here. 
50 Refenring back to Fig. 1 0. after the module synthesis and technology mapping step 1 014 is complete, phase 

2 optimization step 1016 takes place. 

Phase Two Optimization 

55 Phase 2 optimization will be described with reference to the flowchart of Fig. 21 . 

As discussed above, the optimizer/compiler may generate additional circuits (e.g.. 3-input AND gate 1 556 
in Fig. 15B) during the module synthesis. In general, such circuit elements are not mapped to a PLC during 
module synthesis. 
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The first step 2102 of phase 2 optimization is to check If there exists any unmapped circuit elements. If 
so, the system maps the circuit element to a PLC (i.e., allocates a PLC for the unmapped circuit element) in 
step 2104. 

After all circuit elements are mapped to PLC's, the system checks if two different PLC's can be merged 
5 together in step 2106. If so, the two PLC's are merged together Into one PLC in step 2108. 

For example, consider PLC's 2202 and 2204 shown in Fig. 22. One PLC. 2202. Implements a 4-bit adder 
using four lookup tables 2208. 2210, 2212, 2214, and the other PLC 2204 Implements a 4-blt register using 
four flip-flops 2216. 2218, 2220. 2222. The output signals of PLC 2202 (S3, S2, SI, SO) are the input signals 
to PLC 2204. The system recognizes that these two PLC's 2202, 2204 can be merged together, and it merges 
10 the two PLC's Into one PLC 2206. 

These phase 2 optimization operations are beneficial for many reasons. First, more logic resources are 
utilized in one PLC and. so. better circuits in terms of area are produced. Second, locality of circuit elements 
is exploited, producing better circuit performance. Third, routing requirements between PLC's are reduced. 
Refen-ing back to Fig. 10, after phase 2 optimization step 1016, the system will create a netlist format of 
15 the technology mapped circuits for the targeted FPGA in step 1018. This netlist format may vary depending 
on the FPGA to be used. For example, the format is the FAN language for AT&Ts ORCA FPGA. A description 
of the netlist format for other FPGA's is readily available from the FPGA manufacturers. 

In addition to producing a netlist of PLC's, the system also provides structure Information of circuits as 
input to other tools (e.g.. placement tool). For example, in Fig. 138. the optimizer/compiler marks the three 
20 PLCs 1304. 1306, 1308 that Implement one 32x4 user-defined memory as one group of PLCs. Similarly, in 
Fig. 14B the optimizer/compiler marks the three PLCs 1406. 1408, 1410 which Implement a 10-bit adder as 
one group of PLCs. The marking is done by using the appropriate mechanism for the FAN language of the target 
FPGA technology. The placement tool will try to put those PLC's in the same group next to each other. This 
results in a more efficient FPGA implementation. 

25 

Circuit Design Using The Present Invention 

The preceding detailed description described various aspects of the present invention. An example of the 
design of a simple circuit in accordance with the present invention is now provided to illustrate the progress 
30 and relationship of the steps from design through Implementation in an FPGA. 

The example circuit 2300 to be Implemented is shown In Fig. 23. The circuit consists of a 5-bit counter 
2302, a 32x4 memory 2304. and a 4-blt register 2306. The counter 2302 has three Imputs. The ckl signal 2308 
is the counter's clock signal. The rsti signal 2310 is the counter's reset signal. The ckeni signal 2320 Is the 
counter's clock-enable signal. The 5-bit output of the counter, the adin[4;0] signal 2312 Is the address Input to 
35 the memory 2304. As discussed in the prior section describing the HAN language, the adin[4:0] signal speci- 
fication signifies 5 signals adln4, adln3. adln2, adini and adInO. The memory also has a data Input signal 
mdin[3:0] 2314 which is a 4-bit Input The write emable signal of the memory 2304 is designated wreni 2316. 
The output of the memory 2304 is mdout[3:0] signal 2318. 

The output of the memory 2304 Is also the input to the register 2306. The register 2306 also has a reset 
40 signal rstI 2310. a dock signal ckl 2308. and a clock enable signal ckeni 2320. 

A designer could use the present Invention to Implement this circuit by either describing it In the HAN lan- 
^ guage. or by using the graphics tool to describe the circuit First, the HAN description of the example circuit of 
Fig. 23 will be explained. 

The HAN description of the circuit shown In Fig. 23 is as follows: 

45 



50 
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.CIRCUIT testl 

-^^ "i^in (3:0) wrenl rstl ckenl ckl 

•PO rout (3:0J 

.COUNTER cntl 5 

.CTYPE UP 

.DOUT adin(4:0) 

•^^ EDGE_HIGH CKl ckenl 1 

.RESET ASYNC_HIGH rstl 

.ENDCOUNTBR 

- MEM meml 32 4 

.ADDR adiil(4:0) 
•DIN mdin(3:0] 

.DOUT mdout[3:0] 

. WREN wrenl 
15 . ENDMEM 

. REG regl 4 

•^K EDGE^HIGH ck ckenl 1 

-DIN mdout[3:0l 

.DOUT rout [3:0] 

.RESET ASYNC__HIGH rstl 

. ENDCIRCUIT 

25 The details of the HAN language have already been discussed in the section entitled TEXTUAL DESCRIP- 

TION OF CIRCUITS. Therefore, only certain details relating to the specific example will be further discussed. 

In order to indicate that the output of one component is the input to another component, a single signal 
name is used in the description of each component. For example, in the circuit of Fig. 23, the output of the 
counter 2302 is the address input to the memory 2304. This signal is indicated in Fig. 23 at 2312. In order to 

30 indicate this relationship in the HAN language, the same signal name is used in both the memory module de- 
scription and the counter module description. Thus, the .DOUT field in the counter module, which indicates 
the counter's output signal, contains the signal adin[4:01. The .ADDR field of the memory module, which indi- 
cates the address input of the memory, contains the signal adin[4:0]. In a similar manner, the connection of 
the output of the memory 2304 to the input of the register 2306 is indicated in the HAN language by the common 

35 signal mdout[3:0]. 

Similarly, the register 2306 and counter 2302 share the same reset signal rstl 2310, clock signal ckl 2308, 
and clock enable signal ckenl 2320. 

As an alternative to describing this circuit in the HAN format, a circuit designer could use the graphics tool, 
as described above, in the section entitled GRAPHICS TOOL. Referring to Fig. 6, the designer would place 
40 counter icon 650, memory icon 656, and register icon 652 Into the canvas area 608 of the window 600. The 
r -:^ various attributes of each module would then be specified through the use of a multibox. For example, the 
specification of the attributes of the register module 652 in this manner are shown in multibox 630. The attri- 
butes for the memory module and the counter module would be specif ied in a similar manner. 

The primary I/O signals would be then specified by placing the PRIMARY I/O icon 658 in the canvas area 
45 608 and specifying the primary I/O signals by using a multibox. A more informative graphics view can be dis- 
played as shown in Fig. 7. 

If the designer specifies the circuit description using the graphics tool, the system will translate that graph- 
ical description into the HAN file description of the circuit. 

Once the HAN file is created, by either the designer entering the circuit description in the HAN language 
50 directly, or by having the system convert the graphical representation of the circuit into the HAN language, op- 
timization/compilation may begin. 

Referring to Fig. 10, the first step 1004 is reading the input and output signals. In the present example, 
the system will read mdin(3:0], wrenl, rstl. ckenl, ck1 and rout[3:0]. since these signals were specified as 
the primary input and output signals. In step 1006 the system will read the counter module description and will 
55 save the information contained in that specification in step 1008. The system will then read the memory module 
description and the register module description and save the information. Since the register module is last, 
there will be no more modules to read, condition 1010 will be satisfied, and the system will begin phase one 
optimization step 1012. 
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During phase one optimization (see Fig. 11) the system will first determine whether the counter and the 
register use the same reset signal with the same polarity in step 1102. Since both the counter and register use 
the rsti reset signal, the system will eliminate these local reset signals and will replace them with a global reset 
in the FPGA implementation In step 1104. 

5 The step 1106 of checking whether a polarity change will result In improved efficiency follows. Since a 

polarity change would not result in improved efficiency, there is no polarity switch. 

After phase one optimization, the system moves on to module synthesis and technology mapping step 
1014 (Fig. 10). First, a counter Implementation will be developed. As discussed in connection with Figs. 14A 
and 14B, a 5-bit counter will require a 2 PLC implementation. Such an implementation would be as shown In 

10 Fig. 24. Two PLC's 2402, 2404 are required to implement the circuit. Also, the system introduces a carry signal 
2406 between the PLC's. 

Next, the system will implement the memory module. The system will implement the memory module in 
3 PLC's 2408, 2410, 2412. Memory module synthesis is discussed above in greater depth in connection with 
Figs. 13Aand 13B. 

15 Finally, the system will implement the register module. This module will be implemented in one PLC 2414. 

since one PLC of ORCA FPGA can implement a 4-bit register. 

Returning now to Fig. 10, since module synthesis and technology mapping step 1014 is complete, phase 
2 optimization step 1016 will begin. As shown in Fig. 21, the first step 2102 is to check if there exists any circuit 
element that has not been mapped to a PLC. Since there is not such an element, the system moves to step 

20 2106. 

The system recognizes that PLC 2414 (Fig. 24) can be merged to PLC's 2410 and 2412 resulting in one 
less PLC in the final implementation. Thus, the system performs step 2108 (Fig. 21) and produces the circuit 
shown In Fig. 25. Note that PLC's 2502 and 2504 contain not only a 16x4 memory 2506. 2508 but also a 4-blt 
register 2510, 2512. 

25 After the phase 2 optimization is completed, the final step 1018 (Fig. 10) would be to print the resulting 

technology mapped circuit in a netlist format of the target FPGA. 

It is to be understood that the embodiments and variations shown and described herein are illustrative of 
the principles of this invention only and that various modifications may be implemented by those skilled in the 
art without departing from the scope and spirit of the invention. 



Claims 

1 . Asystem for synthesizing circuits from a high level description in a field programmable gate array, wherein 
said field programmable gate array comprises a plurality of programmable logic cells connected by pro- 
grammable routing, the system comprising: 

a computer processor 

a display monitor connected to the computer processor; 

textual data entry means connected to the computer processor. for allowing the entry of a textuaj 
language describing a plurality of electronic circuit elements in terms of parameterized modules; and 
means for compiling said textual language into field programmable gate array configuration data. 

2. The system of claim 1 where in said electronic circuit elements comprise: 

random logic circuit elements and data path circuit elements. 

3. The system of claim 1 further comprising: 

means for receiving a parameterized memory module described in said textual language specifying 
initial contents of said memory module; and 

means for generating a field programmable gate array configuration in which the contents of a 
memory unit are the said specified initial contents. 

4. The system of claim 1 further comprising: 

means for receiving a parameterized module described in said textual language specifying whether 
optimization is to be based on performance or area; and 

means for optimizing the field programmable gate array configuration of said module based upon 
performance or area depending on said textual language specification. 

5. The system of daim 1 wherein said field programnriable gate array configuration data further comprises: 
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information identifying certain programmable logic cells as a group such that said identified group 
of programmable logic cells will be implemented in relative proximity to each other in the field program- 
mable gate array. 

5 6. A system of optimizing a circuit implementation in a field programmable gate array, wherein said field pro- 
grammable gate array comprises a plurality of programmable logic cells connected by programmable rout- 
ing, the system comprising: 
a computer processor; 

means for receiving a description of a first electronic circuit design module specifying an output 
10 signal and a polarity of said output signal, and a second electronic circuit design module specifying an 

input signal and a polarity of said input signal, said output signal of the first module conresponding to the 
Input signal of said second module; and 

means for reversing the signal polarities of said input signal and said output signal to reduce the 
number of programmable logic cells required to implement said first module and said second module in 
15 the field programmable gate array. ; 

7. A system for synthesizing a circuit implementation in a field programmable gate array, wherein said field 
programmable gate array comprises a plurality of programmable logic cells connected by programmable 
routing, the system comprising: 
a computer processor 

means for receiving a textual description of a first electronic circuit design element connected to 
a second electronic circuit design element; 

means for implementing said first electronic circuit design element and said second electronic cir- 
cuit design element in at least one programmable logic cell such that the output of said first electronic 
circuit design element is connected to said second electronic circuit design element; and 

means for optimizing the field programmable gate array implementation of said first and second 
electronic circuit design elements. 
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8. The system of claim 7 wherein said means for optimizing comprises: 

means for implementing said first and second electronic circuit design elements in at least one pro- 
grammable logic cell so as to minimize the number of programmable logic cells. 



9. The system of claim 7 wherein said means for optimizing comprises: 

means for implementing said first and second electronic circuit design elements in at least one pro- 
grammable logic cell so as to minimize the timing of said implementation. 

35 

10, The system of claim 7 wherein said means for optimizing comprises: 

means for implementing said first electronic circuit design element and said second electronic cir- 
cuit design element in one programmable logic cell. 

40 11. A system for synthesizing a circuit from a high level circuit description in a field programmable gate anray 

. comprising: 

a computer processor, 

a graphical display monitor connected to the computer processor for the display of graphical infor- 
mation; 

45 a graphical data entry device connected to the computer processor; 

means for displaying a plurality of icons representative of a plurality of pre-defined electronic circuit 
elements in a first section of said graphical display monitor, said elements comprising random logic circuit 
elements and data path circuit elements; 

means for choosing one of said electronic circuit elements by choosing its representative icon and 
50 for positioning said chosen icon in a second area of said graphical display monitor; 

means for assigning attributes to said electronic circuit elements which are represented by said 
icons in said second area of said graphical display monitor; 

means for generating a textual description of said electronic circuit elements in tern^ of parame- 
terized modules from said chosen icons and assigned attributes; and 
55 means for compiling said textual description of electronic circuit elements into field programmable 

gate array configuration data. 

12. The system of daim 1 or 11 wherein said field programmable gate array configuration data is a field pro- 
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grammable gate array application netlist. 

13. The system of claim 11 further composing: 
means for defining a maao as a set of pre-defined electronic circuit elements; 
means for assigning certain attributes of said pre-defined electronic circuit elements and identi- 
fying said attributes as constants; 

means for identifying certain attributes of said pre-defined electronic circuit elements as variable; 
means for displaying an icon, representative of said macro and displaying said icon in said first sec- 
tion of the graphical display monitor for use as a pre-defined circuit element; and 

means for assigning said variable attributes if said macro is chosen as a design element. 

14. The system of claim 11 further comprising means for defining a derived element, said means comprising: 
means for choosing one of said plurality of icons representative of a pre-defined electronic circuit 

element; 

means for assigning certain attributes of said pre-defined electronic circuit element and identifying 
said attributes as constants; and 

means for displaying an icon, representative of said derived element in said first section of the 
graphical display monitor for use as a pre-defined circuit element. 

1 5. A method for synthesizing a circuit from a high level circuit description in a field programmable gate array, 
wherein said field programmable gate array comprises a plurality of programmable logic cells connected 
by programmable routing, the method comprising the steps of: 

describing a plurality of electronic circuit elements in terms of parameterized modules using a tex- 
tual language; and 

compiling said textual language into field programmable gate array configuration data. 

16. The method of claim 15 wherein said electronic circuit elements comprise: 

random logic circuit elements and data path circuit elements. 

17. The method of claim 1 5 further comprising the steps of: 

30 describing a parameterized memory module in said textual language specifying initial contents of 

said memory module; and 

implementing a field programmable gate array in which the contents of a memory unit are the said 
specified initial contents. 

35 1 8. The method of claim 1 5 further comprising the steps of: 

describing a parameterized module in said textual language specifying whether optimization is to 
be based on performance or area; and 

optimizing the field programmable gate array configuration of said module based upon perfor- 
mance or area depending on said textual language specification:^ 
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19. The method of claim 1 5, wherein said field programmable gate array configuration data further comprises: 
information identifying certain programmable logic cells as a group such that said identified group 
of programmable logic cells will be implemented in relative proximity to each other in the field progranrv 
mable gate array. 
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20. A method for optimizing a field programmable gate array configuration, wherein said field programmable 
gate array comprises a plurality of programmable logic cells connected by programmable routing, the 
method comprising the steps of 

receiving a description of a first electronic circuit design module specifying an output signal and a 
polarity of said output signal, and a second electronic circuit design module specifying an input signal 
and a polarity of said input signal, said output signal of the first module corresponding to the input signal 
of said second module; and 

reversing the signal polarities of said input signal and said output signal to reduce the number of 
programmable logic cells required to implement said first module and said second module in the field pro- 
55 grammable gate array. 

21. A method for synthesizing a circuit implenr^entation in a field programmable gate an-ay. wherein said field 
programmable gate array comprises a plurality of programmable logic cells connected by programmable 
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routing, the method comprising the steps of: 

receiving a textual description of a first electronic circuit design element connected to a second 
electronic circuit design element; 

implementing said first electronic circuit design element and said second electronic circuit design 
element In at least one programmable logic cell such that the output of said first electronic circuit design 
element is connected to said second electronic circuit design element; and 

optimizing the field programmable gate array implementation of said first and second electronic 
circuit design elements. 

22. The method of claim 21 wherein said step of optimizing further comprises the step of: 

implementing said first and second electronic circuit design elements in at least one programmable 
logic ceil so as to minimize the number of programmable logic cells. 

23. The method of claim 21 wherein said step of optimizing further comprises the step of: 

implementing said first and second electronic circuit design elements in at least one programmable 
logic cell so as to minimize the timing of said implementation. 

24. The method of claim 21 wherein said step of optimizing further comprises the step of: 

implementing said first electronic circuit design element and said second electronic circuit design 
element in one programmable logic cell 

25. A method for synthesizing programmable gate array implementations from high level circuit descriptions 
comprising the steps of 

displaying a plurality of icons representative of a plurality of pre-defined electronic circuit design 
elements in a first section of a graphical display monitor, said design elements comprising random logic 
circuit elements and data path circuit elements; 

choosing one of said electronic circuit design elements by choosing its representative icon and for 
positioning said chosen icon in a second area of said graphical display monitor 

assignment attributes to said electronic circuit design elements which are represented by said 
icons in said second area of said graphical display monitor; 

generating a textual description of said electronic circuit design elements in terms of parameterized 
modules from said chosen icons and assigned attributes; and 

compiling said textual description of electronic circuit elements into field programmable gate array 
configuration data. 

26. The method of claim 15 or 25 wherein said field programmable gate array configuration data is a field 
programmable gate array application netlist. 

27. The method of claim 25 further comprising the steps of: 

defining a macro as a set of pre-defined electronic circuit design elements; 

assigning certain attributes of said pre-defined electronic circuit design elements and identifying 
said attributes a constants; 

Identifying certain attributes of said pre-defined electronic circuit design elements as variable; 

displaying an icon, representative of said macro and displaying said icon in said first section of the 
graphical display monitor, for use as a pre-defined circuit design element; and 

assigning said variable attributes if said macro is chosen as a circuit design element 

28. The method of claim 25 further comprising steps for defining a derived element, sard steps comprising: 

choosing one of said plurality of icons representative of a pre-defined electronic circuit design ele- 
ment; 

assigning certain attributes of said pre-defined electronic circuit design element and identifying 
said attributes as constants; and 

displaying an icon, representative of said derived element in said first section of the graphical dis- 
play monitor for use as a pre-defined circuit design element. 
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